package com.onepiece.gen.base.web.config;

import cn.dev33.satoken.interceptor.SaInterceptor;
import cn.dev33.satoken.router.SaRouter;
import cn.dev33.satoken.stp.StpUtil;
import com.onepiece.gen.base.web.config.properties.SecurityProperties;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

import javax.annotation.Resource;

/**
 * @Author tangld
 * Date 2022/12/7 15:16
 * Version 1.0
 * Description TODO
 **/
@Configuration
public class SaTokenConfig implements WebMvcConfigurer {

    @Resource
    private SecurityProperties securityProperties;
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(new SaInterceptor(handler -> {
                    SaRouter.match("/**")
//                            .notMatch("/rcp/patientInfo/**")
                            .check(r -> StpUtil.checkLogin());
                })).addPathPatterns("/**")
                .excludePathPatterns(securityProperties.getExcludes());
    }
}
